package edu.cibertec.dao;

import java.io.IOException;
import java.io.Reader;
import java.util.ArrayList;
import java.util.List;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import edu.cibertec.bean.BeanDetalleExpedienteDTO;
import edu.cibertec.interface1.DetalleExpedienteDAO;

public class SQLDetalleExpedienteDAO implements DetalleExpedienteDAO {
	
	SqlSessionFactory sqlMapper = null;//obtiene la configuracion del archivo
	{
		String archivo = "ConfiguracionIbatis.xml";//abrea la configuracion
		try {
			Reader reader = Resources.getResourceAsReader(archivo);
			sqlMapper = new SqlSessionFactoryBuilder().build(reader);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	@SuppressWarnings("unchecked")
	@Override
	public List<BeanDetalleExpedienteDTO> ListaDetalle(String exp) throws Exception {
		SqlSession session = sqlMapper.openSession();
		
		@SuppressWarnings("rawtypes")
		List lista = new ArrayList<BeanDetalleExpedienteDTO>();
		try {
			lista = (ArrayList<BeanDetalleExpedienteDTO>)session.selectList("DtExpXML.SQL_ListaDetalleExpe",exp);
			
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			session.close();
		}
		return lista;
	}

	@Override
	public int registrarDetalleExp(BeanDetalleExpedienteDTO x) {
		SqlSession sesion=sqlMapper.openSession();
		int estado=0;
		try {
			estado=sesion.insert("DtExpXML.SQL_registrDetalleExp", x);
			sesion.commit();
		} catch (Exception e) {
			e.printStackTrace();
			sesion.rollback();
		}finally{
			sesion.close();
		}
		return estado;
	}

}
